package tree;

import offer.TreeNode;
import sun.dc.pr.PRError;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

/**
 * 序列化是将一个数据结构或者对象转换为连续的比特位的操作，进而可以将转换后的数据存储在一个文件或者内存中，同时也可以通过网络传输到另一个计算机环境，采取相反方式重构得到原数据。
 *
 * 请设计一个算法来实现二叉树的序列化与反序列化。这里不限定你的序列 / 反序列化算法执行逻辑，你只需要保证一个二叉树可以被序列化为一个字符串并且将这个字符串反序列化为原始的树结构。
 *
 * 提示: 输入输出格式与 LeetCode 目前使用的方式一致，详情请参阅 LeetCode 序列化二叉树的格式。你并非必须采取这种方式，你也可以采用其他的方法解决这个问题。
 *
 * 输入：root = [1,2,3,null,null,4,5]
 * 输出：[1,2,3,null,null,4,5]
 * 示例 2：
 *
 * 输入：root = []
 * 输出：[]
 * 示例 3：
 *
 * 输入：root = [1]
 * 输出：[1]
 * 示例 4：
 *
 * 输入：root = [1,2]
 * 输出：[1,2]
 *
 */
public class leetCode297_serialize {

    public static void main(String[] args) {
        String aa = "1,2,#,#,3,4,#,#,5,#,#,1";
        leetCode297_serialize leetCode297_serialize = new leetCode297_serialize();
        leetCode297_serialize.deserialize(aa);
        System.out.println(1);
    }

    String SEP = ",";
    String NULL = "#";
    public String serialize(TreeNode root) {
        if(root == null) return null;
        StringBuilder sb = new StringBuilder();
        serialize(root,sb);
        return sb.toString();
    }

    public void  serialize(TreeNode root,StringBuilder sb){
        if(root == null){
            sb.append(NULL).append(SEP);
            return;
        }
        sb.append(root.val).append(SEP);
        serialize(root.left,sb);
        serialize(root.right,sb);
    }

    public TreeNode deserialize(String data) {
        if(data == null) return null;
        String[] split = data.split(SEP);
        List<String> datas = new ArrayList<>(Arrays.asList(split));
        return deserialize(datas);
    }

    public TreeNode deserialize(List<String> data){
        if(data == null || data.size() == 0)return null;
        String remove = data.remove(0);
        if(remove.equals(NULL)){
            return null;
        }
        TreeNode root = new TreeNode(Integer.parseInt(remove));
        root.left = deserialize(data);
        root.right = deserialize(data);
        return root;

    }



    // Decodes your encoded data to tree.


}

